草庐IT

Python Scapy 引入一个TCP选项

全部标签

go - 为什么当我在 go 中添加另一个阻塞线程时信号处理程序不起作用?

我正在尝试构建一个非常简单的TCP服务器/客户端。我希望程序在被ctrl-c中断时可以关闭连接。如果我只在主线程中发送消息或只接收消息,一切正常。这是客户端的代码。packagemainimport("fmt""os""os/signal""syscall""net""bufio""io""time")const(TIMEOUT=10)funcmain(){iflen(os.Args)2{timeout,_=time.ParseDuration(os.Args[2])}iftimeout==0{timeout=time.Duration(TIMEOUT*time.Second)}con

pointers - 我如何在 Go 中做一个文字 *int64?

我有一个带有*int64的结构类型field。typeSomeTypestruct{SomeField*int64}在我的代码中的某个时候,我想声明一个文字(比如,当我知道所说的值应该是0,或者指向0时,你知道我的意思)instance:=SomeType{SomeField:&0,}...除了这不起作用./main.go:xx:cannotuse&0(type*int)astype*int64infieldvalue所以我试试这个instance:=SomeType{SomeField:&int64(0),}...但这也不起作用./main.go:xx:cannottakethead

go - 在 Go 中编写一个打包的二进制文件的惯用方法是什么,它会产生与这个 Python 相同的输出?

我正在尝试找出如何在Go中编写与以下Python相对应的二进制文件的最佳方法:importstructf=open('tst.bin','wb')fmt='iih'f.write(struct.pack(fmt,4,185765,1020))f.close()我一直在修改我在Github.com和其他一些来源上看到的一些例子但我似乎无法让任何东西正常工作。在Go中执行此类操作的惯用方法是什么?下面是我现在是如何完成的(Golang):packagemainimport("fmt""os""encoding/binary")funcmain(){fp,err:=os.Create("ts

go - 在 Unmarshal 上改变一个字符串

我有一个Profile{}结构,其ID属性类型为uuid.UUID。当我编码它时,我将UUID转换为string,如下所示:typeProfilestruct{Iduuid.UUID}func(profile*Profile)MarshalJSON()([]byte,error){typeAliasProfilereturnjson.Marshal(&struct{Idstring*Alias}{Id:profile.Id.String(),Alias:(*Alias)(profile),})}但是,当我想解码此JSON时,它会提示id是一个字符串。所以我需要在解码时初始化一个UUID

git - 如何用 Go 解压一个 git pack 文件?

我正在尝试解压一个gitpackfile使用纯去。我能找到的唯一库是github.com/jbrukh/ggit/api->parse但我很难弄清楚它应该如何工作。基本上我需要的只是提供包文件的主体并取回git对象(我假设它们是使用zlib压缩的)。我尝试了几种方法,包括fork和尝试使用私有(private)函数,但没有成功(即panic)。packagemainimport(log"github.com/golang/glog""io/ioutil""bytes""bufio""flag""os""github.com/jbrukh/ggit/api/parse")funcmain

调用 Go RPC TCP 服务时 Ruby Socket 客户端挂起

我有一个用Go编写的工作RPCTCP服务,但是当使用Ruby连接到服务时它挂起,因为似乎没有数据通过打开的套接字连接发回。远程RPC函数:packageremoteimport"fmt"//ComposeisourRPCfunctionsreturntypetypeComposestring//DetailsisourexposedRPCfunctionfunc(c*Compose)Details(argstring,reply*string)error{fmt.Printf("Argreceived:%+v\n",arg)*c="somevalue"*reply="Blah!"ret

macos - Golang http 服务器从一个请求中获得了两个远程端口

我正在使用OSX10.11.3的MacbookPro,Golang版本是1.5,以下是我的测试代码packagemainimport("net/http""fmt")funcmain(){http.HandleFunc("/",processGET)c:=&http.Server{Addr:":8080",}c.ListenAndServe()}funcprocessGET(whttp.ResponseWriter,r*http.Request){fmt.Println(r.RemoteAddr)}预期的结果应该是在命令行屏幕上打印客户端的ip和请求端口,但是,每次我连接到http服务

templates - 我可以在 Golang 的另一个模板中使用模板变量吗?

模板1{{define"one"}}{{$var:="Hello"}}{{end}}模板2{{define"two"}}{{template"one"}}Say,{{print$var}}{{end}}我知道上面的例子是无效的。但是有没有办法将"one"模板的变量用到"two"模板中呢? 最佳答案 来自阅读所有文档。答案似乎是不。当一个模板在嵌入到另一个模板之前执行时,该变量就会消失,如果它的值在模板中使用,它将显示为静态文本。在模板one的示例中,$var没有在任何地方使用,因此被丢弃。执行顺序是。加载两个模板。模板one被执行,

ruby - 这个示例 tcp 套接字编程事件顺序安全吗?

我计划提供两项服务。用Ruby编写的HTTPREST服务用Go编写的JSONRPC服务Ruby服务将打开一个到GoJSONRPC服务的TCP套接字连接。它将为收到的每个传入HTTP请求执行此操作。它会通过套接字向Go服务发送一些数据,然后该服务会通过套接字发回相应的数据。Go代码Go服务go看起来像这样(简化):srv:=new(service.App)//thiswouldexposeaProcessmethodrpc.Register(srv)listener,err:=net.Listen("tcp",":8080")iferr!=nil{//handleerror}for{co

c - 像 OpenMP 这样的 golang 中有一个简单的 `parallel for` 吗?

我正在尝试使用并行处理优化拼图,以获得更好的性能。理想情况下,在带有OpenMP的C99中,我应该能够在有问题的for循环之前借助#pragmaompparallelfor来做到这一点,然后应该由系统在CPU之间分配负载。Go的官方文档位于https://golang.org/doc/effective_go.html#parallel,但是,似乎表明对于并行处理,我必须,(0),手动从运行时环境中获取内核数量,(1),遍历所述内核,(2),有效地为每个内核编写一个不同的for循环核心,(3),再次遍历核心以确保所有内容都得到处理。我错过了什么吗?对于最简单的情况,使用古老C的Open